# PATENT ABSTRACTS OF JAPAN

(11)Publication number:

07-084879

(43) Date of publication of application: 31.03.1995

(51)Int.Cl.

G06F 12/08

(21)Application number : 05-224362

(71)Applicant: TOSHIBA CORP

(22)Date of filing:

09.09.1993

(72)Inventor: YAMADA KUNIO

### (54) CACHE MEMORY DEVICE

(57)Abstract:

PURPOSE: To decrease transactions of a bus at the

time of a write miss.

CONSTITUTION: When it is previously known that one line on a cache 1 is all rewritten by successive memory write access to be performed by a CPU, the head address and size of the range of the successive access are set as decision conditions in a decision condition setting part 13 by the specification of software. When the CPU requests memory write access, a write-back cache control part 12 decides whether there is a hit or mishit at a write destination and a decision part 14 decides whether or not the write destination is in the address range indicated with the decision conditions in the decision condition setting part 13. A write miss sequencer 17 is informed of a write miss by the control part 12; when the decision part 14 reports that the conditions are met, a write sequencer 16 is actuated without actuating a read sequencer 15, and requested writing is performed on the cache line of the cache 11.



## LEGAL STATUS

[Date of request for examination]

[Date of sending the examiner's decision of rejection]

[Kind of final disposal of application other than the examiner's decision of rejection or application converted registration]

[Date of final disposal for application]

[Patent number]

[Date of registration]

[Number of appeal against examiner's decision of rejection]

[Date of requesting appeal against examiner's decision of rejection]

[Date of extinction of right]

(19)日本国特許庁(JP)

# (12) 公開特許公報(A)

(11)特許出願公開番号

# 特開平7-84879

(43)公開日 平成7年(1995)3月31日

(51) Int.Cl.6

識別記号

庁内整理番号

FΙ

技術表示箇所

G06F 12/08

310 Z 7608-5B

審査請求 未請求 請求項の数4 OL (全 6 頁)

(21)出願番号

特願平5-224362

(71)出願人 000003078

(22)出願日

平成5年(1993)9月9日

株式会社東芝 神奈川県川崎市幸区堀川町72番地

(72)発明者 山田 邦夫

東京都青梅市末広町2丁目9番地 株式会

社東芝青梅工場内

(74)代理人 弁理士 鈴江 武彦

## (54)【発明の名称】 キャッシュメモリ装置

### (57)【要約】

【目的】ライトミス発生時におけるパスのトランザクシ ョンの減少を図る。

【構成】これから発生するCPUの連続するメモリライ トアクセスによりキャッシュ11上の1ラインが全て書 き換えられることが予め分かっている場合に、ソフトウ ェアの指定により、その連続アクセスの範囲の先頭アド レスとサイズを判定条件として判定条件設定部13に設 定する。CPUからメモリライトアクセスが要求される と、ライトパックキャッシュ制御部12はライト先に対 するヒット/ミスヒットの有無を判定し、判定部14は ライト先が判定条件設定部13の示す判定条件の示すア ドレス範囲に入っているか否かを判定する。 ライトミス シーケンサ17は、制御部12によりライトミスが通知 され、判定部14により条件成立が通知されると、リー ドシーケンサ15を起動せずにライトシーケンサ16を 起動して、キャッシュ11のキャッシュライン上で要求 された書き込みを行わせる。



1

#### 【特許請求の範囲】

【請求項1】主メモリの内容の一部の写しをライン単位 で格納するためのキャッシュを備えたライトバック方式 のキャッシュメモリ装置において、

前記主メモリの利用装置からのメモリアクセス要求を受けて、その要求先のデータが前記キャッシュに存在するか否かのヒット/ミスヒットの判定を行う他、前記主メモリに書き戻されていないキャッシュ上の更新済みデータをキャッシュライン単位で前記主メモリにライトパックするための制御を行うライトパックキャッシュ制御手 10 段と、

前記主メモリからキャッシュへの1キャッシュライン分 のデータの読み込みを行うリードシーケンサと、

前記利用装置により要求されたライト動作を前記キャッシュのキャッシュライン上で行うライトシーケンサと、前記ライトパック制御手段によるライトミス検出に応じて起動されるライトミスシーケンサであって、通常状態では前記リードシーケンサを起動した後前記ライトシーケンサを起動し、前記キャッシュ上の1キャッシュラインが全て書き変わる連続ライト動作状態では、前記リー 20ドシーケンサを起動せずに前記ライトシーケンサを起動するライトミスシーケンサとを具備することを特徴とするキャッシュメモリ装置。

【請求項2】前記キャッシュ上の1キャッシュラインが全て書き変わる連続ライト動作状態にあるか否かを判定し、その判定結果を前記ライトミスシーケンサに通知する判定手段を更に具備することを特徴とする請求項1記載のキャッシュメモリ装置。

【請求項3】前記連続ライト動作の対象となるメモリ領域を前記判定手段による上記判定に用いられる判定条件として設定するための判定条件設定手段を更に具備し、前記判定手段は、前記利用装置からライト指定のメモリアクセスが要求された場合には、前記判定条件設定手段に設定されている判定条件と要求アクセス先をもとに上記判定を行うことを特徴とする請求項2記載のキャッシュメモリ装置。

【請求項4】前記判定条件設定手段への前記判定条件の 設定がソフトウェア処理により行われることを特徴とす る請求項3記載のキャッシュメモリ装置。

#### 【発明の詳細な説明】

[0001]

【産業上の利用分野】この発明は、主メモリの一部の写 しが置かれるキャッシュでのライトミス発生時に好適な ライトバック方式のキャッシュメモリ装置に関する。

[0002]

【従来の技術】従来、主メモリの一部の写しが置かれるキャッシュを備えたライトパック方式のキャッシュメモリ装置では、CPUからのライト要求に対してライトミスが発生した場合、ライトミスシーケンサにより次のようなキャッシュ制御が行われるのが一般的であった。

【0003】まず、ライトミスシーケンサによりリードシーケンサが起動され、ライト要求先のデータを含む、キャッシュ1ラインサイズ分の主メモリ上の該当データ

2

【0004】次に、ライトミスシーケンサによりライトシーケンサが起動され、そのキャッシュライン上で、ライト要求先に対応した箇所のデータの変更(更新)が行われる。

部分が、一旦キャッシュラインへ読み込まれる。

【0005】このデータ変更後のキャッシュラインは、ライトバックの対象となり、CPUの空き時間等を利用して、主メモリにライトバックされる(書き戻される)。この結果、当該キャッシュラインのデータにより、主メモリ上の該当するデータ部分が全て置き換えられ、CPUからのライト要求に応じてキャッシュライン上で行われたデータ更新結果が、その1ラインに対応する主メモリ上のデータ部分のうちの該当箇所(CPUからのライト要求先)に反映される。一方、他の箇所のライトバック後の内容は元の内容に一致し、正しい状態に維持される。

#### 20 [0006]

【発明が解決しようとする課題】上記したように、従来は、キャッシュにおいてライトミスが発生した場合には、キャッシュ1ラインサイズ分の主メモリ上の該当するデータ部分を一旦キャッシュラインへ読み込んでから、そのキャッシュライン上で、要求されたデータの変更を行うのが一般的であった。

【0007】このように、キャッシュ1ラインサイズ分の主メモリデータ部分をキャッシュラインに読み込んで要求されたデータの変更を行うのは、変更の対象となっていなかった箇所の内容が、主メモリへのライトバックにより変更されないようにするためである。

【0008】しかし、この従来方式では、ライトミスの発生の都度、主メモリからキャッシュへのキャッシュ1 ライン分の読み込みが発生するため、ライトミスの発生 回数が多くなるとパスのトランザクションも増加し、性 能が低下するという問題があった。

【0009】この発明は上記事情を考慮してなされたものでその目的は、キャッシュ上の1ラインが全て書き換えられることが予め分かっている場合があり、このような場合には、ライトミス発生に応じて主メモリから1ライン分のデータを読み込まなくても、主メモリへのライトバックによる不都合は何ら生じないことに着目し、キャッシュ上の1ラインが全て書き換えられることが予め分かっている場合のライトミス発生時における、主メモリからの該当データ部分の読み込みを抑制することにより、バスのトランザクションの減少を図ることができるキャッシュメモリ装置を提供することにある。

[0010]

【課題を解決するための手段】この発明は、ライトバッ 50 ク方式のキャッシュメモリ装置において、主メモリの利 3

用装置からのメモリアクセス要求を受けて、その要求先 のデータがキャッシュに存在するか否かのヒット/ミス ヒットの判定を行う他、主メモリに書き戻されていない キャッシュ上の更新済みデータをキャッシュライン単位 で主メモリにライトバックするための制御を行うライト パックキャッシュ制御手段と、主メモリからキャッシュ への1キャッシュライン分のデータの読み込みを行うり ードシーケンサと、主メモリ利用装置により要求された ライト動作をキャッシュのキャッシュライン上で行うラ イトシーケンサと、ライトパック制御手段によるライト 10 ミス検出に応じて起動されるライトミスシーケンサであ って、通常状態ではリードシーケンサを起動した後ライ トシーケンサを起動し、キャッシュ上の1キャッシュラ インが全て書き変わる連続ライト動作状態では、リード シーケンサを起動せずにライトシーケンサを起動するラ イトミスシーケンサとを備えたことを特徴とするもので ある。

【0011】また、この発明は、キャッシュ上の1キャ ッシュラインが全て書き変わる連続ライト動作状態にあ るか否かを判定し、その判定結果をライトミスシーケン 20 サに通知する判定手段を更に備えたことをも特徴とす る。

【0012】また、この発明は、連続ライト動作の対象 となるメモリ領域を上記判定手段が用いる判定条件とし て設定するための判定条件設定手段を更に備え、主メモ リ利用装置からのメモリライトアクセス要求時には、こ の判定条件と要求アクセス先をもとに判定手段による上 記判定が行われるようにしたことをも特徴とする。

#### [0013]

**ひなどの)主メモリ利用装置の連続する主メモリライト** アクセスにより、キャッシュ上の1ラインが全て書き換 えられることが予め分かっているような場合には、ソフ トウェアの指定により、例えば、そのライトアクセスの 先頭アドレスとその範囲を示すサイズからなる判定条件 が、判定条件設定手段に設定される。

【0014】判定手段は、主メモリ利用装置からの主メ モリライトアクセス要求があると、要求されたライトア ドレスが判定条件設定手段に設定されている判定条件の 示すアドレス範囲内に入っているか否かを判定し、入っ 40 ている場合には、条件成立をライトミスシーケンサに通 知する。

【0015】一方、ライトパックキャッシュ制御手段 は、主メモリ利用装置からの主メモリライトアクセス要 求があると、その要求されたライトアクセス先のデータ がキャッシュに存在するか否か、即ちライト時のヒット /ミスヒットの有無を調べ、その結果をライトミスシー ケンサに通知する。

【0016】 ライトミスシーケンサは、ライトバックキ ャッシュ制御手段からライトミスが通知されると、判定 50 2 に書き戻すための制御等を行う。このキャッシュ制御

手段から条件成立 (を示す判定結果) が通知されている か否かを調べる。もし、条件成立が通知されているなら ば、ライトミスシーケンサは、判定手段によってリード シーケンサを起動させないことが指示されているものと 判断し、従来のようにリードシーケンサを起動した後に ライトシーケンサを起動するのではなく、リードシーケ ンサを起動せずにライトシーケンサを起動する。

【0017】このように、主メモリ利用装置からの主メ モリライトアクセス要求が判定条件設定手段の示す条件 に合致している場合、即ちキャッシュ上の1ラインが全 て書き換えられる主メモリライトの場合には、リードシ ーケンサによる主メモリからキャッシュへのデータ読み 込みが行われないことから、バスのトランザクションの 減少が図れる。

【0018】しかも、主メモリからキャッシュへのデー 夕読み込みが行われなくても、連続するライトアクセス によりキャッシュ上の1ラインが全て書き換えられるこ とから、その後、ライトパックキャッシュ制御手段のラ イトパック制御により、当該キャッシュラインのデータ がキャッシュから主メモリにライトパックされても、何 ら問題はない。

#### [0019]

【実施例】図1はこの発明の一実施例に係るライトバッ ク方式のキャッシュメモリ装置の構成を示すプロック図 である。同図において、1はライトバック方式のキャッ シュメモリ装置、2は主メモリ、3はキャッシュメモリ 装置1および主メモリ2が接続されている外部パスであ

【0020】キャッシュメモリ装置1は、キャッシュ1 【作用】上記の構成において、これから発生する(CP 30 1、ライトバックキャッシュ制御部12、判定条件設定 部13、判定部14、リードシーケンサ15、ライトシ ーケンサ16およびライトミスシーケンサ17を有して

> 【0021】キャッシュ11は、主メモリ2の内容の一 部の写しを、ライン (ブロック) 単位で格納するのに用 いられる。但し本実施例では、ライトバック方式を適用 しているため、キャッシュ11のキャッシュラインの内 容が、常に主メモリ2の該当データ部分と同一であると は限らない。この主メモリ2とは内容が異なるキャッシ ュラインをダーティなキャッシュラインと呼び、主メモ リ2へのライトパック(書き戻し)の対象となる。

> 【0022】ライトパックキャッシュ制御部12は、キ ャッシュメモリ装置1全体の制御を司るもので、CPU (図示せず) からのメモリアクセス要求を受けて、その 要求先のデータがキャッシュ11に存在するか否かのヒ ット/ミスヒットの判定を行う他、主メモリ2に書き戻 されていないキャッシュ11上の更新済みデータをキャ ッシュライン単位で主メモリ2にライトパックするため の制御、即ちダーティなキャラクタのデータを主メモリ

のためのタグメモリ (ディレクトリメモリ) は省略され ている。

【0023】判定条件設定部13は、ライトバックキャ ッシュ制御部12によりライトミスが検出された場合 に、ライト要求先のデータを含む、キャッシュ1ライン サイズ分の主メモリ2上の該当データ部分をキャッシュ 11に読み込む必要があるか否かの判定に用いられる条 件(判定条件)を設定するためのものである。この判定 条件は、CPUからの主メモリライトアクセスが連続し て行われ、キャッシュ11上の1ラインが全て書き換え 10 と同様である。 られることが予め分かっている場合にソフトウェアの指 定により設定されるもので、そのライトアクセスの先頭 アドレスとその範囲を示すサイズからなる。そこで、判 定条件設定部13は、この判定条件の設定のために、上 記先頭アドレスが設定されるアドレスレジスタ131 と、サイズが設定されるサイズレジスタ132とで構成 されている。

【0024】判定部14は、CPUからの主メモリライ トアクセス要求が判定条件設定部13に設定されている 判定条件に合致するか否かを判定する。リードシーケン 20 サ15は、主メモリ2からキャッシュ11への1キャッ シュライン分のデータの読み込みを行う。

【0025】 ライトシーケンサ16は、キャッシュ11 への書き込みを行う。ライトミスシーケンサ17は、ラ イトパックキャッシュ制御部12によるライトミス判定 時の動作を制御するもので、判定部14の判定結果をも とに、リードシーケンサ15を起動するか否かを決定す

【0026】次に、図1の構成の動作を図2のフローチ ャートを参照して説明する。まず、これから発生するC 30 PUの連続する主メモリライトアクセスにより、キャッ シュ11上の1ラインが全て書き換えられることが予め 分かっているものとする。

【0027】このような場合には、ソフトウェアの指定 (に従うCPUの動作) により、その連続アクセスの範 囲の先頭アドレスとサイズからなる情報が、ライトミス 時にキャッシュ1ラインサイズ分のデータを主メモリ2 からキャッシュ11に読み込む必要があるか否かの判定 条件として、判定条件設定部13に設定される。具体的 には、判定条件中の先頭アドレスが判定条件設定部13 40 内のアドレスレジスタ131に、当該判定条件中のサイ ズが判定条件設定部13内のサイズレジスタ132に、 それぞれ設定される。

【0028】このような判定条件設定が行われるのは、 例えばオペレーティングシステム(OS)のメモリ管理 における1ページのゼロクリアなどの場合やブロックコ ピーの場合などである。

【0029】さて、以上の判定条件設定動作の後、CP Uから主メモリライトアクセスのためのアドレスとコン トロール信号が出力されたものとする。このアドレスと 50 は、ライトバックキャッシュ制御部12により決定され

コントロール信号は、ライトパックキャッシュ制御部1 2および判定部14に導かれる。

【0030】ライトパックキャッシュ制御部12は、C PUからのコントロール信号がライト要求を示している 場合、同CPUからのアドレスの指定するライトアクセ ス先のデータがキャッシュ11に格納されているか否 か、即ちライト時のヒット/ミスヒットの有無を調べ、 その結果をライトミスシーケンサ17に通知する。ここ でのライトパックキャッシュ制御部12の動作は、従来

【0031】一方、判定部14は、CPUからのコント ロール信号がライト要求を示している場合、同CPUか らのアドレスが、判定条件設定部13に設定されている 判定条件で示されるアドレス範囲、即ちアドレスレジス タ131の示すアドレスから始まるサイズレジスタ13 2の示すサイズ分のアドレス範囲内に入っているか否か を判定する。

【0032】判定部14は、CPUからのアドレスが上 記アドレス範囲内に入っている場合に限り、即ちCPU からのコントロール信号がライト要求を示し、且つCP Uからのアドレスが判定条件設定部13の示す判定条件 に合致している場合に限り、ライトミスシーケンサ17 に対して条件成立を通知する。

【0033】 ライトミスシーケンサ17は、ライトパッ クキャッシュ制御部12からライトミスが通知される と、以下に述べるように、図2のフローチャートに従う 処理を行う。

【0034】まずライトミスシーケンサ17は、判定部 14から条件成立(を示す判定結果)が通知されている か否かを調べる (ステップS1)。もし、条件成立が通 知されているならば、ライトミスシーケンサ17は、判 定部14によってリードシーケンサ15を起動させない ことが指示されているものと判断する。この場合、ライ トミスシーケンサ17は、従来のようにリードシーケン サ15を起動した後にライトシーケンサ16を起動する のではなく、リードシーケンサ15を起動せずに、直ち にライトシーケンサ16を起動する(ステップS2)。

【0035】即ちライトミスシーケンサ17は、ライト 要求先のデータを含む、キャッシュ1ラインサイズ分の 主メモリ2上の該当データ部分を読み込むことなく、ラ イトシーケンサ16を起動して、キャッシュ11の1キ ャッシュライン上のライト要求先に対応する位置のデー 夕を、CPUからのライトデータに書き換えさせる。

【0036】この場合、リードシーケンサ15による主 メモリ2からキャッシュ11へのデータ読み込みが行わ れないことから、外部パス3のトランザクションが減少 する。

【0037】ここで、書き換えの対象となるキャッシュ 11上のキャッシュライン (を示すラインアドレス)

7

る。もし、この決定されたキャッシュラインの内容が主 メモリ2へのライトパックの対象となっている場合に は、同ラインのデータをライトパックキャッシュ制御部 12が主メモリ2に書き戻した後、上記の書き換えが行 われる。

【0038】これに対し、判定部14から条件不成立が 通知されている場合には、ライトミスシーケンサ17は、従来のように、まずリードシーケンサ15を起動して (ステップS3)、ライト要求先のデータを含む、キャッシュ1ラインサイズ分の主メモリ2上の該当データ 10部分をキャッシュ11に読み込ませた後、ライトシーケンサ16を起動する (ステップS4)。

【0039】なお、ライトバックキャッシュ制御部12でライトヒットが検出された場合には、ライトシーケンサ16が起動されて、ヒットしたキャッシュ11のキャッシュライン上のライト要求先に対応する位置のデータが、CPUからのライトデータに書き換えられる。

【0040】以上のように、本実施例によれば、CPUからの連続する主メモリライトアクセスの要求先が、判定条件設定部13に設定されている判定条件の示すアド20レス範囲内に入っている限りは、ライトミスが発生したとしてもリードシーケンサ15は起動されず、このため主メモリ2からキャッシュ11への該当する1ライン分の読み込みは行われず、ライトシーケンサ16によって単にキャッシュ11のキャッシュライン上でのデータ書き換えが行われるだけである。

【0041】このキャッシュ11の当該キャッシュラインは、上記の主メモリライトアクセスが連続して行われると、全てCPUからのライトデータに書き換えられる。したがって、その後、ライトバックキャッシュ制御 30部12のライトバック制御により、当該キャッシュラインのデータをキャッシュ11から主メモリ2にライトバックすると、主メモリ2上の該当するデータ部分を全てCPUからのライトデータに正しく書き換えたことになる

【0042】即ち、CPUからの連続する主メモリライトアクセスの要求先が、判定条件設定部13に設定されている判定条件の示すアドレス範囲内に入っている場合には、ライトミス発生時にリードシーケンサ15を起動しないで(ライトシーケンサ16による)キャッシュ1401上でのデータ書き換えを行ったとしても、連続アクセスの後のライトバックにより、主メモリ2上の該当するデータ部分は全て正しいデータに書き換えられる。

【0043】なお、前記実施例では、CPUからの主メ モリライトアクセスが連続して行われ、キャッシュ11 上の1ラインが全て書き換えられることが予め分かって いる場合に、そのライトアクセスの先頭アドレスとその 範囲を示すサイズが判定条件として用いられる場合について説明したが、これに限るものではない。

8

【0044】例えば、ページング方式を適用するシステムにあっては、ページと主メモリ(2)上のメモリ領域との対応関係を示すページテーブルの各エントリに、対応ページへのアクセスが連続して行われるか否かを示すフラグピットを設け、OSのメモリ管理における当該ページのゼロクリアなどの場合には、対応するページテーブル内エントリのフラグヒットをオンするようにしても構わない。この方式では、当該ページを対象とする主メモリライトアクセスの期間中は、判定部14からライトミスシーケンサ17に対して条件成立を通知するようにすればよい。

### [0045]

【発明の効果】以上詳述したようにこの発明によれば、 キャッシュ上の1ラインが全て書き換えられる連続ライ ト動作状態における、主メモリ利用装置からの主メモリ ライトアクセス要求を判定し、この条件に合致する要求 に対しては、ライトミス検出時であってもリードシーケ ンサを動作させずに直ちにライトシーケンサを動作させ ることにより、主メモリからキャッシュラインへの該当 データ部分の読み込みを行わずに、当該キャッシュライ ン上での書き込みを行わせる構成としたので、バスのト ランザクションを減少して、性能向上を図ることができ る。しかも、主メモリからキャッシュへのデータ読み込 みが行われなくても、連続するライトアクセスによりキ ャッシュ上の1ラインが全て書き換えられることから、 その後、ライトバックキャッシュ制御手段のライトバッ ク制御により、当該キャッシュラインのデータがキャッ シュから主メモリにライトパックされても、何ら問題は ない。

#### 【図面の簡単な説明】

【図1】この発明の一実施例に係るライトバック方式の キャッシュメモリ装置の構成を示すプロック図。

【図2】 同実施例におけるライトミス発生時のライトミスシーケンサ17の動作を説明するためのフローチャート。

#### 【符号の説明】

1…キャッシュメモリ装置、2…主メモリ、3…外部パス、11…キャッシュ、12…ライトパックキャッシュ 制御部、13…判定条件設定部、14…判定部、15… リードシーケンサ、16…ライトシーケンサ、17…ライトミスシーケンサ、131…アドレスレジスタ、132…サイズレジスタ。

[図1]



【図2】

